mpe | 您所在的位置:网站首页 › hypersnips for math › mpe |
Markdown Preview Enhanced for VSCode
▶︎allrunning...
语言规则
结构体
标题:#
列表
无序列表: -
有序列表:数字 + .
任务列表:- [ ] 与 - [x]
引用:>
便签块:!!! + 类型 + 标题
表格:|
代码块:``` + 代码 + ```
行内代码:` + 代码 + `
文字效果
斜体:* 或 _
加粗:** 或 __
删除线:~~
高亮:==
上标:^
下标:~
排版功能
目录
分割线:---
打印分页
其他功能
LaTeX:$ 与 $$
链接:[文字] + (链接)
网页
标题
图片:![](图片地址)
Emoji
绘图
定义缩写:*[缩写]: 全称
导入外部文件:@import "文件名"
代码
Markdown 文件
表格
CSS 样式
HTML 语言与 CSS 样式
空行:
空格
半方占位符:
全方占位符:
居中:
下划线:
折叠内容:
CSS 样式
自定义全局样式
模板样式
局部样式
输出文件
元数据
HTML
PDF
Word
更多
语言规则
Enter 起到换行或结构体分块的作用,但不能实现空行,也就是多次 Enter 是无效的。 Space 只能空一格,不能连续空格,通常也起到声明结构体的作用。 Tab 用来改变结构体层级。 实现其他的需求需要使用HTML语言。 结构体不同的符号可以声明不同的结构体,比如列表、引用、便签块等等。每一个声明结构体的符号后都需要空一格再写后续内容,结构体与结构体之间的层级关系用 Tab 来控制。 标题:#用 # 来表示一级标题,## 表示二级标题,以此类推。 例子 ### 三级标题 三级标题 列表 无序列表: -例子 - 第一点 - 第二点 - 第二点中的第一小点 第一点 第二点 第二点中的第一小点注意 如果安装了 Markdown All in One 插件,默认 Tab 是只空2格而非4格,但不影响改变层级的效果。如果想改成4格,需要在设置中的 Markdown › Extension › List: Indentation Size 中选择 inherit。 有序列表:数字 + .例子 1. 第一点 2. 第二点 1. 第二点中的第一小点 第一点 第二点 第二点中的第一小点提示 如果安装了 Markdown All in One 插件,回车即可自动按顺序编号,再次回车可以取消编号。 任务列表:- [ ] 与 - [x]用 - [ ] 表示未完成的任务,用 - [x] 表示已完成的任务。 例子 - [ ] 任务一 - [x] 任务二 任务一 任务二 引用:>例子 > MPE 是最好的 Markdown 插件。 > ——鲁迅MPE 是最好的 Markdown 插件。 ——鲁迅 便签块:!!! + 类型 + 标题例子 !!! note 注意 明天开会。注意 明天开会。 支持以下类型的便签块: 表格:|表格的声明相对比较复杂,第一行是表头,第二行是控制对应列的文字排版,第三行及以下是表格的内容。 例子 | 表头1 | 表头2 | 表头3 | | :--------------------: | :----------------- | -----------------: | | 两个冒号居中 | 冒号在左左对齐 | 冒号在右右对齐 | | > | `>` 合并左边单元格 | `^` 合并下方单元格 | | 空着不写合并右边单元格 | | ^ | 表头1 表头2 表头3 两个冒号居中 冒号在左左对齐 冒号在右右对齐 > 合并左边单元格 ^ 合并下方单元格 空着不写合并右边单元格提示 由于表格的书写过于繁琐,如果有书写表格的需求,建议安装 HyperSnips for Math 插件,在 snippet 文件中加入以下代码,即可通过输入 table + 行数 + 列数 来生成表格。 function createTable(rows, cols) { let ret = ""; for (let i = 0; i < parseInt(rows) + 2; i++) { for (let j = 0; j < parseInt(cols); j++) { if (i === 1) { ret += "|:---:"; } else { ret += "| "; } } ret += "|\n" } return ret; } priority 300 snippet `table(\d)(\d)` "create table with rows and columns" wA `` rv = createTable(m[1], m[2]); `` endsnippet 代码块:``` + 代码 + ```用三个键盘左上角类似顿号的符号来声明代码块的开始与结束,起始符后面接语言类型,比如 python、json、markdown 等等。 例子 ```python print('Hello world!') ``` print('Hello world!')通过在语言类型后自定义 class 和 attribute,可以对代码块进行一些自定义操作,例如: 添加行号 例子 ```python {.line-numbers} def add(x, y): return x+y ``` def add(x, y): return x+y高亮某几行 例子 ```python {highlight=[1-3, 5]} def add(x, y): return x+y def multiply(x, y): return x*y ``` def add(x, y): return x+y def multiply(x, y): return x*y执行代码 例子 ```python {cmd} def add(x, y): return x+y print(add(1, 2)) ``` def add(x, y): return x+y print(add(1, 2)) ▶︎allrunning...注意 需要按 F1 选择 Markdown Preview Enhanced: Run All Code Chunks 执行代码,如果执行不了,在设置中勾选 Markdown-preview-enhanced: Enable Script Execution。 行内代码:` + 代码 + `例子 欢迎来到 python 的世界,输入 `print('Hello World!')` 打个招呼吧!欢迎来到 python 的世界,输入 print('Hello World!') 打个招呼吧! 文字效果在文字两边加上不同的符号,可以有不同的文字效果,比如加粗、斜体、上下标等等。 斜体:* 或 _例子 *一个星号* 或 _一个下划线_一个星号 或 一个下划线 提示 如果安装了 Markdown All in One 插件,可以选中文字按 Ctrl + I 达到斜体的效果。 加粗:** 或 __例子 **两个星号** 或 __两个下划线__两个星号 或 两个下划线 提示 如果安装了 Markdown All in One 插件,可以选中文字按 Ctrl + B 达到加粗的效果。 平时单独加粗或者单独斜体用 * 或 _ 都可以,但如果既要加粗又要斜体,则需要 * 与 _ 组合使用: 例子 **_组合使用_**组合使用 删除线:~~例子 ~~两个波浪线~~两个波浪线 高亮:==例子 ==两个等于号==两个等于号 上标:^例子 2^th^2th 下标:~例子 x~1~x1 排版功能 目录按 F1 打开功能搜索,选择 Markdown Preview Enhanced: Create TOC, Ctrl + S 保存即可。在标题后加 {ignore} 即可忽略该标题不放入目录。 #### 不在目录中显示 {ignore} 不在目录中显示注意 如果安装了 Markdown All in One 插件,需要在设置中取消 Markdown > Extension > TOC: Update On Save 的勾选,因为这个设置会导致保存时用的是 Markdown All in One 的目录生成功能而不是 MPE 的。 分割线:---例子 --- 打印分页输入 pagebreak 并 Ctrl + / 注释,即可在打印成 pdf 的时候在相应位置分页。 其他功能 LaTeX:$ 与 $$MPE 的 LaTeX 语句用 KaTeX 渲染,一个美元符号代表行内公式,两个则代表块公式。 例子 $1 + 1 = 2$ $$ 1 + 1 = 2 $$1+1=21 + 1 = 21+1=2 1+1=21 + 1 = 21+1=2 提示 如果安装了 Markdown All in One 插件,按一下 Ctrl + M 即进入行内公式模式,按两下则进入块公式模式。 链接:[文字] + (链接)用 [文字](链接) 的形式可以制作一个“传送门”,在文中以文字的形式出现,点击可以前往对应的链接,链接的形式包括网页和标题。 网页用 [文字](网址) 来生成网页链接。 例子 你不会[百度](https://www.baidu.com)吗?你不会百度吗? 标题用 [文字](#标题) 来生成标题链接。 例子 [点击此处前往文字效果](#文字效果)点击此处前往文字效果 注意 英文均为小写,空格换成 -。如果有同名标题,第二个出现的标题需要在标题后加 -1,第三个需要加 -2,以此类推。 例子 [第一个“CSS 样式”](#css-样式) [第二个“CSS 样式”](#css-样式-1)第一个“CSS 样式” 第二个“CSS 样式” 图片:![](图片地址)图片地址可以是本地路径(绝对路径或相对路径均可),也可以是 URL。 例子 ![](https://static.wikia.nocookie.net/sonicpokemon/images/b/b2/Psyduck_AG_anime.png)如果觉得复制路径麻烦,可以按 F1 选择 Markdown Preview Enhanced: Image Helper,以图形界面的形式上传图片。 提示 如果安装了 Paste Image 插件,即可复制图片后通过 Ctrl + Alt + V 的快捷键直接粘贴图片。 Emoji支持 emoji 表情显示,表情代码可查找emoji表。 例子 :smile: :flushed: :sweat: :sob: :joy: :+1: :ok_hand: :point_down: :clap: :muscle: :pray: :heart: :fire: :boom: :star2: :shit: :zzz:😄 😳 😓 😭 😂 👍 👌 👇 👏 💪 🙏 ❤️ 🔥 💥 🌟 💩 💤 绘图MPE 支持好几种绘图语言,见官方文档。个人认为 Mermaid 算是比较常用且方便的,可以绘制流程图等。 MPE 中内置了三个 Mermaid 主题,可以在设置中找到 Markdown-preview-enhanced: Mermaid Theme 进行更改。 定义缩写:*[缩写]: 全称例子 *[CNN]: Convolutional Neuraul Network Chairman Zheng is proficient in CNN.Chairman Zheng is proficient in CNN. 注意 鼠标悬浮即可看到全称(pdf 不支持该效果)且全局生效(即整篇文章出现这一字样都会有下划虚线,不管是定义前还是定义后)。 注意 如果中英夹杂,英文与中文之间需要有空格才会生效,与标点符号之间不需要有空格。 导入外部文件:@import "文件名"可以通过 @import "文件名" 导入外部文件,比如导入代码、图片、css样式等等,但不可以有层级关系,即不能在其他结构体下导入。 代码导入代码形成代码块,同样可以在后面声明 class 和 attribute。 @import "test.py" {.line-numbers} print('Hello world!') Markdown 文件导入 Markdown 文件即可做到重复利用某个文字片段。 @import "test.md"可重复利用的片段 表格导入 csv 格式的表格可以避免繁琐的表格输入。 @import "test.csv" 姓名 分数 levi 100 CSS 样式见 HTML 语言与 CSS 样式-CSS 样式。 HTML 语言与 CSS 样式Markdown 是 HTML 的简化版,因此也支持 HTML 语句,但 Markdown 本身就是为了注重内容而生,用 HTML 语句实际上破坏了 Markdown 的初衷,所以尽量只用 CSS 样式来控制排版。 空行:由于 Markdown 中回车键最多只能空一行,如果想要空多行,需要用 HTML 语句实现。 例子 第一行 第二行 第四行第一行 第二行 第四行 空格 半方占位符:半方占位符相当于一个英文字符的大小,比 Markdown 中的空格要大一点点。 例子 ab a b a bab a b a b 全方占位符:全方占位符相当于一个中文字符的大小。 例子 哈哈 哈哈哈哈 哈哈 居中:用 标签可以对文字或图片进行居中,但不能对表格进行居中。 例子 与头标签空一行与头标签空一行 下划线:可以使用 对文字添加下划线。 例子 html u 标签html u 标签 折叠内容:可以通过 来折叠文字,并用 来显示简要文字。 例子 展开查看 内容要与上面空一行! 展开查看内容要与上面空一行! 注意 输出 pdf 的话,折叠块是打不开的。 CSS 样式MPE 的 CSS 样式分为全局(对所有文件生效)和局部(只对指定文件生效),全局样式又分模板样式和自定义样式,一般调整样式的顺序为 graph LR 自定义全局样式 --> 模板样式 --> 自定义局部样式; 自定义全局样式全局的自定义样式需要按 F1 选择 Markdown Preview Enhanced: Customize CSS 来打开。 其中以 . 开头的为类(class),默认的 .markdown-preview.markdown-preview 即为全局类,在其中写的样式会应用到全局。 例子 .markdown-preview.markdown-preview { mark { background-color: #f8aba6;// 梅色 } }这个 mark 样式让我所有文件中的高亮都变成梅色。 除了默认应用的全局类,还可以自定义手动调用的类。 例子 .centertable { width: auto; display: table; margin-left: auto; margin-right: auto; }这个类可以对表格进行居中显示,只需在要居中的表格前后加上容器标签 。 例子 | 注意 | 注意 | | :----------------------: | :--------------------: | | 头标签与表格之间需要空行 | 标签与上下文也需要空行 | 注意 注意 头标签与表格之间需要空行 标签与上下文也需要空行 模板样式模板样式可以在预览窗口中右键选择 Preview Theme: 局部样式局部样式需要通过 @import 的操作来导入,可以在元数据区声明要用的类。具体使用方式可以参考官方文档。 输出文件 元数据在 Markdown 文件的顶端输入 --- ---这两条虚线区域内的代码被称为元数据(metadata),为 YAML 语言。元数据控制着输出的效果。 HTML由于 Markdown 是 HTML 语言的简化版本,html 文件能最大程度地接近预览的效果。在预览窗口中右键选择 HTML > HTML (cdn hosted) 即可生成对应的 html 文件。 提示 输出 html 时默认侧边栏收缩,如果需要默认展开,则可以输入以下元数据: --- html: toc: true ---如果不需要侧边栏,则为 false。默认是 undefined。 PDF如果安装了 Chrome 浏览器,直接在预览窗口中右键选择 Chrome (Puppeteer) > PDF 即可导出 pdf。 如果没有安装 Chrome 浏览器,但有使用 Chromium 内核的浏览器(比如 Edge),你需要找到该浏览器对应的执行文件(比如 Edge 的执行文件路径为 C:\Program Files (x86)\Microsoft\Edge\Application\msedge.exe),在设置中将这个路径输入 Markdown-preview-enhanced: Chrome Path,即可按上面相同的操作导出 pdf。 注意 Puppeteer 默认 printBackground 的属性是 false,即在预览中设置的主题(模板样式)并不会打印出来,如果想要打印主题,可以按 F1 选择Prefrences: Open Settings (JSON),在里面加入"markdown-preview-enhanced.printBackground": true的设置。 注意 在文件中包含 LaTeX 公式时,输出成 pdf 可能导致公式不显示,这是因为输出的速度太快了,公式还没来得及渲染。可以输入以下元数据来延迟输出: --- puppeteer: timeout: 3000 ---提示 如果想针对性地调整更多的设置,比如页边距之类的,可以在预览窗口右键选择 Open in Browser,在浏览器的 打印 选项中进行调整。 Word想要输出成 Word 格式的文件,需要安装 Pandoc,并输入以下元数据: --- output: word_document ---但 Pandoc 对于很多 HTML 语言以及 CSS 样式都不太支持,因此输出成 Word 基本上只能对内容进行一个保留。 更多更多的功能可以参考官方文档。 |
CopyRight 2018-2019 实验室设备网 版权所有 |